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APPLICATION PROGR2iMMING INTERFACE 
FOR MEASURING DEVICES 



BACKGROUND OF THE INVENTION 
5 This application is being filed with a 

microfiche appendix of computer program listings 
consisting of one (1) fiche having fifty-one (51) 
frames. 

A portion of the disclosure of this patent 
10 document contains material which is subject to 

copyright protection. The copyright owner has no 
objection to the facsimile reproduction by anyone of 
the patent document or the patent disclosure, as it 
appears in the Patent and Trademark Office patent 
15 file or records, but otherwise reserves all 

copyright rights whatsoever. 

Field Of The Invention 

The present invention concerns an 
2 0 application programming interface (API) usable by a 

software developer when writing an application 
program^ such as a color calibration program, that 



uses a color measuring device. In particular, the 

present invention relates to an API that provides a 
common interface between such an application program 
and plural different types of color measuring 
5 devices. 

Description Of The Related Art 

One common use of color measuring devices 
is to calibrate color fidelity of color recording 

10 devices. Typically, the recording device (such as a 

color laser beam printer or ink jet printer) records 
color patches on a recording medium. The color 
values of the patches are measured by the color 
measuring device, the measured values are compared 

15 against expected (or ideal) values, and the 

comparisons are used to calibrate the recording 
device . 

Color measuring devices come in many 
different physical structures, such as XY tables, 

2 0 strip readers, hand-held patch readers, and flatbed 

scanners, and operate in different ways using 
different numbers and types of sensors . Color 
patches are input in different ways to color 
measuring devices which have different physical 
25 structures. For example, patches are input to an XY 

table on a sheet that has an array of patches 
printed thereon, whereas patches are input to a 
strip reader on strips that each have one or more 
rows of patches printed thereon. The sensors that 

3 0 actually perform color measurements are positioned 

on patches in different ways depending on the 
physical structures of the color measuring devices. 

In order to make accurate color 
measurements for use in calibrating a color 
35 recording device, the color measuring devices 

themselves must be calibrated properly. For 
example, for some color measuring devices to 



position their sensor (s) accurately, the positioning 
mechanism in the color measuring devices must be 
calibrated. In addition, the sensors in some color 
measuring devices must be calibrated so as to ensure 
5 proper color measurements. Depending on the numbers 

and types of sensors as well as the physical 
structures of the color measuring devices, 
calibration of the position of the sensors and 
calibration of the sensors differ among different 

10 types of color measuring devices. 

In addition, application programs that use 
color measuring devices should provide interfaces to 
the user. These interfaces should include 
instructions to the user at various points 

15 throughout operations performed using the color 

measuring devices . The timing and content of these 
instructions also differ among different color 
measuring devices. 

As a result of the foregoing differences in 

2 0 operation among the different types of color 

measuring devices, a different command set is needed 
for each different type of device. Application 
programs that use the color measuring devices often 
must include different numbers of calls to commands 

2 5 in the different command sets in order to perform a 

same operation with different color measuring 
devices. In addition, the application programs 
often must include different interfaces for each 
different type of color measuring device. These 

3 0 different command sets and interfaces greatly 

complicate the task of writing application programs 
that perform color measurements. As a result, 
conventional application programs for performing 
color measurements must include separate and often 
3 5 lengthy routines for taking color measurements with 

each different type of supported device. In 
addition, once a conventional application program is 



written, that application program cannot use new 
types of color measuring devices, because the new 
device would require calls to commands in a new 
command set . 

5 

SUMMARY OF THE INVENTION 
Accordingly, there is a need for an 
application programming interface (API) that allows 
a software developer to write a single set of 

10 routines for taking color measurements using plural 

different types of color measuring devices. 

The present invention addresses the 
foregoing need by providing an application 
programming interface that abstracts the operations 

15 needed to perform color measurements . An 

application program only needs to include calls to 
the functions in this API in order to use any 
supported type of color measuring device. The API 
in turn calls the necessary commands for performing 

20 color measurement operations. 

In order to allow the application program 
to provide appropriate instructions during 
operations performed with a color measuring device, 
certain functions in the API are called numerous 

25 times in order to complete their respective 

operations. In order to enable the application 
program to call such a function a correct number of 
times, the API provides the application program with 
flow control data of the number of times that the 

3 0 function needs to be called so as to complete its 

operation with a particular color measuring device. 
The API also preferably provides the application 
program with display values for display so as to 
instruct the user in manipulating the color 

3 5 measuring device. 

By virtue of the foregoing, the application 
program does not need to include separate routines 



for each different type of supported color measuring 
device. Instead, the application program need only 
include calls to the functions in the API and 
include mechanisms for handling display values and 
5 flow control data provided by the API. Moreover, if 

the API is implemented in a dynamically linkable 

library (DLL) , an existing application program that 
calls the functions in the API can use new types of 
color measuring devices by linking to an updated 

10 version of the DLL. 

Accordingly, in one aspect the invention is 
an API that provides a common interface between an 
application program and plural different types of 
color measuring devices each having at least one 

15 color measuring sensor. The API includes plural 

functions for operating any of the plural different 
types of color measuring devices. In order to 
complete an operation performed by at least one of 
the plural functions, the function that performs the 

2 0 operation must be called a number of times which is 

different for at least two different types of color 
measuring devices. For a particular color measuring 
device, the API provides the application program 
with flow control data of the number of times that 

2 5 the function must be called. This flow control data 

preferably can be provided by the function, in the 
form of a call-again value or as a numerical value, 
or by a separate function in the API such as a get- 
device-capabilities function. In some embodiments 

3 0 of the invention, a combination of these methods of 

providing the flow control data is utilized. 

Preferably, the functions in the API also 
provide the application program with display values 
which are different for at least two different types 
3 5 of color measuring devices. The display values are 

for display to a user, preferably by the application 



program, so as to instruct the user in manipulating 
the color measuring device that is being operated. 

In another aspect, the invention is an API 
that provides a common interface between an 
5 application program and plural different types of 

color measuring devices each having at least one 
color measuring sensor. The API includes plural 
functions for operating any of the plural different 
types of color measuring devices. The plural 

10 functions include a calibrate-position function, a 

calibrate- sensor function, a move-to-patch function, 
and a make -measurement function. 

The calibrate-position function calibrates 
a relative position of a recording medium with 

15 respect to any of the plural different types of 

color measuring devices. Preferably, the calibrate- 
position function provides the application program 
with at least one display value that is to be 
displayed so as to instruct a user to position the 

2 0 recording medium or to position any of the color 

measuring sensors . 

The calibrate-sensor function calibrates 
any of the color measuring sensors o£ SiTliy Of the 
plural different types of color measuring devices. 
25 Preferably, the calibrate-sensor function provides 

the application program with at least one display 
value that is to be displayed so as to instruct the 
user in calibrating the sensor. 

The move-to-patch function relatively 

3 0 positions any of the color measuring sensors and a 

color patch for any of the plural different types of 
color measuring devices. The move-to-patch function 
is provided with a logical color patch number by the 
application program. In order to relatively 
3 5 position the color patch and any of the color 

measuring sensors for some color measuring devices, 
the move-to-patch function preferably can provide 



the application program with a display value which 

instructs the user to manipulate the color measuring 

devices or to move the recording medium. In order 
to relatively position the color patch and any of 
5 the color measuring sensors for other color 

measuring devices, the move-to-patch function 
preferably causes the color measuring device to move 
the recording medium or to move the color measuring 
sensors. In any case, the move-to-patch function 

10 preferably provides the application program with a 

recalibrate value in a case that the relative 
position of the recording medium needs to be 
recalibrated, for example when a new recording 
medium is loaded into the color measuring device. 

15 The make -measurement function makes a color 

measurement of the patch at which any of the color 
measuring sensors is relatively positioned, and the 
make -measurement function provides the application 
program with a color measurement value for the color 

20 patch. The make -measurement function preferably 

provides the application program with at least one 
display value that is to be displayed so as to 
instruct the user in making the color measurement . 
In addition, the make -measurement function 

2 5 preferably provides the application program with a 

recalibrate value in a case that any of the color 
measuring sensors needs to be recalibrated. 

In order to complete an operation performed 
by at least one of the plural functions, the 

3 0 function that performs the operation must be called 

a number of times which is different for at least 
two different types of color measuring devices. For 
a color measuring device that is being operated, the 
API provides the application program with flow 
3 5 control data of the number of times that the 

function must be called. The flow control data 
preferably can be provided by the function, either 



in the form of a call-again value or a numerical 
value, or by a get-device-capabilities function 
included in the API . 

The computer-executable process steps for 
5 the functions in the API preferably are stored in a 

dynamically linkable library (DLL) . Thus, updated 
API functions can be used by an application program 
to access new types of measuring devices simply by 
linking the application program to the DLL. 

10 The API according to the invention relieves 

application programs from the burden of having to 
include separate routines for taking color 
measurements with each different type of supported 
color measuring device. Instead, in order to take 

15 color measurements with any type of supported color 

measuring device, the application program need only 
include calls to functions in the API. The API 
itself handles the different interfaces to the 
different types of color measuring devices. As a 

2 0 result, the application program is far simpler to 

write . 

This brief summary has been provided so 
that the nature of the invention may be understood 
quickly. A more complete understanding of the 
25 invention can be obtained by reference to the 

following detailed description of the preferred 
embodiments thereof in connection with the attached 
drawings . 

3 0 BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a representational view of a 
computer system in which color fidelity of a color 
printer is calibrated using a color measuring 
device . 

3 5 Figure 2 is a detailed block diagram 

showing the internal architecture of the computer 
system shown in Figure 1. 
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Figure 3 is a block diagram for explaining 
a system for calibration of color fidelity of a 
color printer by a color calibration program 
according to the invention. 
5 Figure 4 is a block diagram for explaining 

a structure of a measuring device application 
programming interface (API) according to the 
invention. 

Figure 5 is a representational view of a 
10 development system for development of an application 

program using a measuring device API according to 
the invention. 

Figure 6 is a detailed block diagram 
showing the internal architecture of the development 
15 system shown in Figure 5 . 

Figures 7A to 7C are flowcharts for 
explaining color calibration by a color calibration 
program using a measuring device API according to 
the invention. 

2 0 Figure 8 is a block diagram for explaining 

a variation of the structure of the measuring device 
API according to the invention. 

Figure 9 is a block diagram for explaining 
another variation of the structure of the measuring 

25 device API according to the invention. 



DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
Figure 1 is a representational view of a 
computer system in which color fidelity of a color 

3 0 printer is calibrated using a color measuring 

device. Shown in Figure 1 are color printer 1 and 
computer system 6, together with a variety of color 
measuring devices, such as XY table 2, strip 
reader 3, hand-held patch reader 4, and scanner 5. 

35 Color printer 1 is depicted in Figure 1 as 

an ink jet printer. However, any printer capable of 
printing color images on recording media can be 



utilized by a color calibration program written 
according to the invention, such as ink jet printers 
and laser printers. Color printer 1 prints color 
images in response to print jobs received from 
computer system 6 over printer interface 8 . 

Measuring device 10 is a color measuring 
device that is used to generate color measurements 
of color patches input thereto. The color 
measurements generated by color measuring device 10 
are transmitted over measuring device interface 9 to 
computer system 6. Examples of measuring device 10 
include XY table 2, strip reader 3, and hand-held 
patch reader 4 for reading individual color patches. 

Color patches are input to each of the 
different types of color measuring devices in 
different ways. For example, patches are input to 
XY table 2 on a sheet that has an array of patches 
printed thereon, whereas patches are input to strip 

reader 2 on strips that eacli have one or more rows 

of patches printed thereon. The sensors that 
actually perform color measurements are positioned 
on patches in different ways depending on the 
physical structures of the color measuring devices. 
For example, XY table 2 typically includes motors 
and gimbals for automatically positioning the 
sensors, while hand-held patch reader 4 typically 
must be manually positioned over a patch. 

Flatbed scanner 5 can also serve as a color 
measuring device, provided that scanner 5 is 
properly calibrated. Color patches are input to 
flatbed scanner 5 in a similar manner as the patches 
are input to XY table 2, namely on a sheet that has 
an array of patches printed thereon. 

The different color measuring devices also 
can use entirely different types and arrangements of 
sensors for making the color measurements. For 
example, color measuring device 10 can be a 
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spectrometer (i.e., a spectrophotometer or a 
spectroradiometer) , which uses sensors that 
preferably measure light intensity for frequencies 
across the entire visible spectrum. Alternatively, 
5 color measuring device 10 can be a colorimeter or 

densitometer, which uses sensors that measure light 
intensity for XYZ or RGB components of the spectrum. 

In any case, each of the color measuring 
devices have at least one color sensor for making 

10 color measurements. In order to ensure accurate 

color measurements, the sensor (s) should be 
calibrated. In addition, depending on the type of 
measuring device 10, a relative position of a 
recording medium with respect to the device might 

15 have to be calibrated. In particular, each time a 

new recording medium (e.g., strip or sheet) is input 
to color measuring device 10, the position of the 
recording medium should be recalibrated so that the 
color measuring device can properly locate color 

2 0 patches printed thereon. 

Because of the different ways that color 
patches are input and measured by the different 
types of color measuring devices, a different 
command set is needed to calibrate and to make color 
25 measurements with each different type of color 

measuring device . 

As shown in Figure 1, computer system 6 is 
connected to printer l through printer interface 8 
and measuring device 10 through measuring device 

3 0 interface 9. Provided with computer system 6 are 

display 12 which may be a color monitor, keyboard 14 
for entering user commands, and pointing device 15 
such as a mouse for pointing to and for manipulating 
graphical user interfaces and other objects 
35 displayed on display 12. 

Computer system 6 also includes a mass 
storage device such as fixed disk 16 . This mass 
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storage device is for storing computer- executable 
process steps for a color calibration program and a 
measuring device DLL according to the invention, as 
well other application programs and an operating 
5 system including a printer driver and a measuring 

device driver. Such storage may also be provided by 
a CD-ROM (not shown) . 

It should be understood that, although a 
programmable general -purpose computer is shown in 

10 Figure 1, a dedicated computer terminal or other 

type of data processing equipment can utilize the 
present invention. 

Figure 2 is a detailed block diagram 
showing the internal architecture of computer system 

15 6 . As shown in Figure 2 , computer system 6 includes 

central processing unit 23 which interfaces with 
computer bus 24. Also interfacing with computer 
bus 24 are fixed disk 16, main memory (RAM) 26, read 
only memory (ROM) 27, floppy disk interface 29, 

2 0 display interface 3 0 to display 12 (not shown) , 

keyboard interface 32 to keyboard 14 (not shown) , 
pointing device interface 33 to pointing device 15 
(not shown) , printer interface 8 to color printer 1, 
and measuring device interface 9 to measuring 
25 device 10. 

Main memory 26 interfaces with computer 
bus 24 so as to provide RAM storage to CPU 23 during 
execution of software applications. More 
specifically, CPU 23 loads process steps from fixed 

3 0 disk 16, another storage device, or some other 

source such as a network (not shown) , into main 
memory 26. CPU 23 then executes the stored process 
steps from main memory 2 6 in order to execute 
application programs. Data such as print data and 
3 5 color measurement data can be stored in main 

memory 26, where the data can be accessed by CPU 23 
during execution of the process steps. 
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As shown in Figure 2, fixed disk 16 
typically contains operating system 36, application 
programs 37, measuring device DLL 3 8 according to 
the invention, and other files and data. Operating 
5 system 3 6 includes printer driver 4 0 and measuring 

device driver 41. Measuring device driver 41 is one 
of plural different types of measuring device 
drivers corresponding to the type of measuring 
device 10 connected to computer system 6. Examples 

10 of measuring device driver 41 include XY table 

driver 43 for XY table 2, strip reader driver 44 for 
strip reader 3, patch reader driver 45 for hand-held 
patch, reader 4, and scanner driver 46 for scanner 5. 
Some or all of these drivers can be stored on fixed 

15 disk 16. 

Application programs 3 7 include color 
calibration program 48. The structure and operation 
of color calibration program 48 is explained in more 
detail below with reference to Figure 3 . 

2 0 Measuring device DLL 3 8 is a library of 

functions that are called by an application program 
so as to use any of plural different color measuring 
devices supported by the DLL. In order to write an 
application program that calls these functions, a 
25 software developer uses a measuring device API 

according to the invention, as explained below with 
reference to Figures 5 and 6 . 

Figure 3 is a block diagram for explaining 
a system for calibration of color fidelity of a 

3 0 color printer by a color calibration program 

according to the invention. In Figure 3, color 
calibration program 48 runs on computer system 6 and 
sends print data 51 for printing color patches to 
printer driver 40. The color patches are for use in 
35 calibration of color printer 1. 

Color calibration program 4 8 makes API 
calls 52 to functions provided by measuring device 



DLL 3 8 in order to make color measurements of the 
color patches. According to the invention, since 
the DLL encapsulates the functionality needed to 
operate many different color measuring device, it is 
5 possible for the color calibration program 48 to 

call exactly the same functions, in exactly the same 
order, no matter which of plural different types of 
color measuring devices are connected. Because of 
the difference in devices, however, the API often 

10 needs to have certain functions repeated, or 

operator interaction performed, in order for the 
different devices to be usable by a single 
application. Accordingly, in response to API 
calls 52, the functions in the DLL provide color 

15 calibration program 48 with information that the 

application needs to ensure that the API functions 
are called correctly. Such information might 
include, for example, display values for display by 
the application to the user so as to prompt the user 

2 0 for some user intervention (such as to prompt the 

user to insert a next sheet of patches into the 
measuring device) , and the information might further 
include flow control data that instruct the 
application to alter its control flow such as by 
25 calling particular DLL functions multiple times 

until a needed result (such as position calibration) 
is achieved. Display values and flow control 
data 53 provided to color calibration program 48 are 
explained in more detail below with reference to 

3 0 Figures 4, 8 and 9. 

Color calibration program 4 8 also is 
provided with color measurements 54 by the DLL. 
Based on color measurements 54, color calibration 
program 48 sends color adjustment commands 55 to 
35 printer driver 40 so as to adjust color fidelity of 

color printer 1. The operation of color calibration 
program 4 8 in printing and measuring the color 
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patches and adjusting the color printer is explained 
in more detail below with reference to Figures 7A 
to 7C. 

In response to print data 51 received from 

color calibration program 48, printer driver 40 
sends print job 57 to color printer 1. Likewise, in 
response to color adjustment commands 55 received 
from color calibration program 48, printer driver 40 
sends printer commands 58 to color printer 1. 

Color printer 1 prints printed color 
patches 61 in response to print job 57 received from 
printer driver 40. The user inputs these color 
patches to color measuring device 10. 

Measuring device DLL 38 provides a common 
interface between color calibration program 48 and 
plural different types of color measuring devices. 
As mentioned above, functions in measuring device 
DLL 3 8 are called by API calls 52 from color 
calibration program 48. The functions in measuring 
device DLL 3 8 make device driver calls 62 based on 
API calls 52 in order to operate measuring 
device 10. Device driver calls 62 are calls to a 
device driver corresponding to the type of color 
measuring device 10. For example, if measuring 
device 10 is an XY table, device driver calls 62 are 
calls to an XY table driver. In response to device 
driver calls 62, measuring device DLL 3 8 is provided 
with color measurements 64 by measuring device 
driver 41. Measuring device DLL 38 in turn provides 
color calibration program 48 with display values and 
flow control data 53 and color measurements 54 . The 
flow control data preferably is based at least in 
part on device characteristics 65 received from 
measuring device driver 41. The structures of the 
functions in measuring device DLL 3 8 according to 
the invention are explained in more detail below 
with reference to Figures 4, 8 and 9, and the 



operation of the functions is explained with 
reference to Figures 7A to 7C. 

Measuring device driver 41 is a device 
driver corresponding to the type of measuring 
5 device 10. Measuring device driver 41 receives 

device driver calls 62 from the functions in 
measuring device DLL 38. In response to these call, 
measuring device driver 41 sends device commands 66 
to measuring device 10, which provides color 
10 measurements 67 to measuring device driver 41. 

Color measurements 67 in turn are provided to 
measuring device DLL 38 as color measurements 64. 

As mentioned above, measuring device 10 

receives printed color patches 61 as input. 

15 Measuring device 10 makes color measurements 67 of 

printed color patches 61 in accordance with device 
commands 66 received from measuring device 
driver 41. Measurement device 10 provides color 
measurements 67 to measuring device driver 41. 

2 0 Figure 4 is a block diagram for explaining 

functionality provided in the DLL and accessed from 
the application through the API. 

Briefly, the measuring device DLL 
illustrated in Figure 4 is accessed through a 

2 5 measuring device API according to the invention. 

The API provides a common interface between an 
application program and plural different types of 
color measuring devices each having at least one 
color measuring sensor. The interface includes 

3 0 plural functions for operating any of the plural 

different types of color measuring devices. In 
order to complete an operation performed by one or 
more of the functions, the function that performs 
the operation must be called a number of times which 
35 is different for different types of color measuring 

devices . For a color measuring device that is being 
operated, the API provides the application program 



with flow control data of the number of times that 
the function must be called. In Figure 4, this flow 
control data is provided for some of the functions 
by a separate get-device capabilities function. 
This flow control data is provided for other 
functions by the functions themselves, in the form 
of "call -again" values provided by the functions to 
the color calibration program. The functions in the 
API also preferably provide the application program 
with display values which are different for 
different types of color measuring devices. The 
values are displayed by the color calibration 
program to a user so as to instruct the user in 
manipulating the color measuring device that is 
being operated. 

In more detail. Figure 4 shows measuring 
device DLL 3 8 which is accessed by an application 
program through a measuring device API according to 
the invention. Thus, the API provides an interface 
for a software developer to write an application 
program that calls the functions in the DLL 
illustrated in Figure 4 . The functions provide an 
interface between color calibration program 48 and 
measuring device driver 41. Measuring device 
driver 41 in turn communicates with measuring device 
10 through measuring device interface 9. 

Measuring device driver 41 is a device 
driver corresponding to the type of measuring 
device 10. Thus, brackets next to measuring device 
driver 41 in Figure 4 indicate that measuring device 
driver 41 is one of plural different device drivers 
such as XY table driver 43, strip reader driver 44, 
patch reader driver 45, and scanner driver 46. 
Likewise, brackets next to measuring device 10 in 
Figure 4 indicate that measuring device 10 is one of 
XY table 2, strip reader 3, hand-held patch reader 4 
for reading individual color patches, and scanner 5. 
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It should be noted that the various drivers 
and devices shown in Figure 4 are only 
representative of the possible drivers and devices 
that can be operated using the API according to the 
5 invention. 

In Figure 4, measuring device DLL 38 
includes at least the following functions, which are 
provided to an application program through a 
measuring device API according to the invention: 

10 get-device-capabilities 71, calibrate-position 72, 

calibrate-sensor 73, move-to-patch 74, and make 
measurement 75. Arrows pointing into blocks for 
these functions indicate information provided to the 
functions by color calibration program 48. 

15 Likewise, arrows pointing out of blocks for these 

functions indicate information provided by the 
functions to color calibration program 48. 

Information can be provided in various 
different ways to the functions by color calibration 

20 program 48 and by the functions to color calibration 

program 48. For example, information can be 
provided to a function as a passed variable, by 
modification of a shared (e.g., global) variable or 
data space, by passing a pointer to a memory 

2 5 location that stores the information, or through 

messages in a message-based environment. Likewise, 
information can be provided by a function as a 
returned value, by modification of a shared variable 
or data space, by modification of a memory location 

3 0 pointed to by a pointer, or through messages. Any 

or all of these methods, as well as any other 
additional methods, can be utilized by measuring 
device DLL 3 8 according to the invention. 

Get-device-capabilities function 71 
35 according to the invention provides color 

calibration program 48 with flow control data for 
calibrate-position function 72 and calibrate-sensor 
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function 73. In particular, get-device-capabilities 
function 71 provides color calibration program 4 8 
with number of calls 77, thereby indicating the 
number of calls that must be made to calibrate- 
5 position function 72 in order to calibrate a 

position of a recording medium with respect to 
measuring device 10. Likewise, get-device- 
capabilities function 71 provides color calibration 
program 48 with number of calls 78, thereby 

10 indicating the number of calls that must be made to 

calibrate-sensor function 73 in order to calibrate 
the sensor (s) of measuring device 10. 

The DLL preferably determines the flow 
control data by querying measuring device driver 41, 

15 or measuring device 10, for device characteristics 

65. The functions in measuring device DLL determine 
the flow control data based at least in part on 
device characteristics 65. For example, if the 
device characteristics identify the type of 

20 measuring device 10, the functions can determine the 

flow control data using a look-up table. 
Alternatively, device characteristics 65 can include 
the flow control data directly, for later use by the 
different functions in the DLL. Get-device- 

25 capabilities function 71 preferably queries the 

device driver or the device for the device 
characteristics . 

Calibrate-position function 72 is called to 
calibrate a relative position of a recording medium 

3 0 with respect to any of the plural different types of 

color measuring devices. In order to calibrate the 
relative position of the recording medium, 
calibrate-position function 72 might have to be 
called more than once. The number of calls depends 

3 5 at least in part on the type of measuring device 10. 

As discussed above, get-device-capabilities function 
71 according to the invention provides color 



calibration program 48 with number of calls 77 that 
must be made to calibrate-position function 72 in 
order to complete the position calibration 
operation. Number of calls 7 7 preferably is based 
5 at least in part on device characteristics 65. 

Each time calibrate-position function 72 is 
called, the user might be required to perform a task 
such as positioning the sensor (s), positioning the 
recording medium, or otherwise manipulating 

10 measuring device 10. Calibrate-position function 72 

preferably provides display values 8 0 to color 
calibration program 48, and program 48 displays 
display values 80 to a user so as to instruct the 
user to perform these tasks, as necessary. 

15 Display values 80, as well as all other 

display values provided by measuring device DLL 38, 
can include text and/or graphics, or any other type 
of values displayable by computer system 6. Because 
the application program actually displays the 

2 0 display values, the application program can 

determine the form of the display. For example, the 
application program can display text or graphics 
based on the display values. The display values do 
not necessarily need to be displayed visually. For 

2 5 example, if the application program includes text- 

to-speech functionality, the program can generate 
speech based on the display values . 

Calibrate-sensor function 73 is called to 
calibrate the sensor (s) of any of the plural 

3 0 different types of color measuring devices. In 

order to calibrate the sensor (s), calibrate-sensor 
function 73 might have to be called more than once. 
As discussed above, get-device-capabilities 
function 71 according to the invention provides 
35 color calibration program 48 with number of calls 78 

that must be made to calibrate-sensor function 7 3 so 
as to complete the sensor calibration operation. 
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Number of calls 78 preferably is based at least in 
part on device characteristics 65. 

Each time calibrate-sensor function 73 is 
called, the user might be required to perform a task 
5 such as manipulating measuring device 10. 

Calibrate-sensor function 73 preferably provides 
display values 82 to color calibration program 4 8 
for display by the program to a user so as to 
instruct the user to perform any such tasks. 

10 Move-to-patch function 74 is called to 

relatively position the sensor (s) and a color patch 
for any of the plural different types of color 
measuring devices. Move-to-patch function 74 is 
provided with logical color patch number 84 by color 

15 calibration program 48. In response, move-to-patch 

function 74 moves the sensor (s) or the recording 
medium so as to position the sensor (s) at the 
corresponding color patch, provides color 
calibration program 48 with display values 85 so as 

20 to instruct the user to move the sensor (s) or the 

recording medium, or both. 

In order to relatively position the 
sensor (s) at the patch, move-to-patch function 74 
might have to be called multiple times, depending on 

25 the type of measuring device 10. For example, if 

the color patch corresponding to color patch 
number 84 is on a next sheet or strip of recording 
medium, move-to-patch function 74 might have to be 
called a first time so as to instruct a user to 

3 0 change the sheet or strip, a second time so as to 

recalibrate the position of the recording medium (by 
providing a recalibrate value) , and then a third 
time so as to move to the first patch on the 
recording medium. The number of times that move-to- 

3 5 patch function 74 needs to be called preferably is 

determined by the function based at least in part on 
device characteristics 65. If move-to-patch 



function 74 needs to be called multiple times, move- 
to-patch function 74 provides color calibration 
program 48 with flow control data indicating whether 
the function has been called the necessary number of 
5 times. As shown in Figure 4, this flow control data 

takes the form of call-again value 86, which is 
provided if move-to-patch function 74 has not been 
called the necessary number of times. 

In some situations, and in particular when 

10 a new recording medium is input to measuring 

device 10, the relative position of the recording 
medium and measuring device 10 might have to be 
recalibrated. Move -to -patch function 74 provides 
color calibration program 48 with recalibrate 

15 value 87 in such situations. 

Make -measurement function 75 is called to 
make a color measurement of the patch at which the 
sensor (s) are relatively positioned. Make- 
measurement function 75 provides color calibration 

2 0 program 48 with color measurement 54 for the color 

patch. In addition, make -measurement function 75 
preferably provides color calibration program 48 
with display values 8 9 for display by the program to 
instruct the user to perform any necessary tasks for 

2 5 making the color measurement. 

As with move-to-patch function 74, make- 
measurement function 75 might have to be called 
multiple times in order to complete its operation. 
The number of times that make -measurement 

3 0 function 75 needs to be called preferably is 

determined by the function based at least in part on 
device characteristics 65. If make -measurement 
function 75 needs to be called multiple times, make- 
measurement function 75 provides color calibration 
35 program 48 with flow control data indicating whether 

the function has been called the necessary number of 
times. As shown in Figure 4, this flow control data 



takes the form of call -again value 90, which is 
provided if make -measurement function 75 has not 
been called the necessary number of times. 

If the sensor (s) need to be recalibrated 
5 after a color measurement, for example after a 

certain number of color measurements, make- 
measurement function 75 provides color calibration 
program 48 with recalibrate value 91. 

Figure 5 is a representational view of a 

10 development system for development of an application 

program using a measuring device API according to 
the invention. As shown in Figure 5, development 
system 100 is provided with display 102 which may be 
a color monitor, keyboard 104 for entering user 

15 commands and for entering code for an application 

program, and pointing device 105 such as a mouse. 
Development system 10 0 also includes a mass storage 
device such as fixed disk 106. This mass storage 
device is for storing computer-executable process 

2 0 steps for an operating system, software development 

programs, and a measuring device API according to 
the invention. Such storage may also be provided by 
a CD-ROM (not shown) . 

It should be understood that, although 

2 5 development system 100 is shown as a programmable 

general -purpose computer in Figure 5, a dedicated 
computer terminal or other type of data processing 
equipment can be used to write application programs 
utilizing the API according to the present 

3 0 invention. 

Figure 6 is a detailed block diagram 
showing the internal architecture of development 
system 100. As shown in Figure 6, development 
system 100 includes central processing unit 113 
35 which interfaces with computer bus 114. Also 

interfacing with computer bus 114 are fixed 
disk 106, main memory (RAM) 116, read only memory 



(ROM) 117, floppy disk interface 119, display 
interface 12 0 to display 102 (not shown) , keyboard 
interface 122 to keyboard 104 (not shown) , and 
pointing device interface 123 to pointing device 105 
5 (not shown) . 

Main memory 116 interfaces with computer 
bus 114 so as to provide RAM storage to CPU 113 
during execution of software applications. More 
specifically, CPU 113 loads process steps from fixed 

10 disk 10 6, another storage device, or some other 

source such as a network (not shown) , into main 
memory 116. CPU 113 then executes the stored 
process steps from main memory 116 in order to 
execute application programs. Data such as code for 

15 an application program utilizing a measuring device 

API according to the invention can be stored in main 
memory 116, where the data can be accessed by 
CPU 113 during execution of the process steps. 

As shown in Figure 6, fixed disk 106 

20 typically contains operating system 126, application 

programs 127, and measuring device API 128 according 
to the invention. Operating system 12 6 typically is 
a windowing operating system and preferably is 
compatible with operating system 3 6 of computer 

25 system 6. Application programs 127 preferably 

includes software development programs 13 0 for 
developing application programs for making color 
measurements with color measuring devices . 

A software developer uses software 

3 0 development programs 13 0 to write code for an 

application program such as color calibration 
program 48. The software developer includes calls 
to functions provided by measuring device API 12 8 in 
order to have the application program make color 

3 5 measurements with any color measuring device 

supported by the API . 
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The API preferably includes headers 
corresponding to the functions in measuring device 
DLL 38. When the software developer compiles the 
code for application program using software 
5 development programs 13 0, these headers allow the 

application program to access the functions in 
measuring device DLL 38. These functions provide a 
common interface to any of the plural supported 
color measuring devices. Therefore, as long as the 

10 application program includes code for handling flow 

control data and display values returned by the 
functions in the DLL, as described sJdOVQ With 
reference to Figures 3 and 4, the application 
program is able to make color measurements with any 

15 of the plural supported color measuring devices. 

Figures 7A to 7C are flowcharts for 
explaining a representative color calibration 
application using a measuring device API according 
to the invention. 

2 0 In step S701 in Figure 7A, color 

calibration program 4 8 generates print data 51 for 
color patches for calibration of color fidelity of 
color printer 1. In step S702, color calibration 
program 48 sends print data 51 to printer driver 40, 

2 5 which in turn sends print job 57 to color printer 1 

based on print data 51. Color printer 1 prints the 
print job onto a recording medium, resulting in 
printed color patches 61. 

In step S703, color calibration program 48 

3 0 makes API call 52 to get -device-capabilities 

function 71 in measuring device DLL 38. In 
response, get-device-capabilities function 71 
provides flow control data to calibration 
program 48. This flow control data preferably 
3 5 includes number of calls 77 and number of calls 78, 

which indicate the number of times calibrate- 
position function 71 and calibrate -sensor function 



72 need to be called in order to perform their 
respective operations. 

In step S704, the relative position of the 
sensor (s) with respect to the recording medium is 
5 calibrated. Figure 7B is a flowchart for explaining 

position calibration according to the invention. 

In step S705 of Figure 7B, color 
calibration program 48 calls calibrate-position 
function 72. This function sends device driver 
10 calls 62 to measuring device driver 41, which in 

turn sends device commands 66 to measuring device 10 
so as to calibrate the relative position of the 
sensor (s) . 

In step S706, color calibration program 48 
15 determines if calibrate-position function 72 

provided display values 80. it calibrate-position 

function 72 did provide display values 80, color 
calibration program 48 displays the display values 
to the user, such as on display 12, in step S707. 

20 In step S708, color calibration program 48 

determines if calibrate-position function 72 has 
been called the number of times indicated by 
number of calls 77. If calibrate-position 
function 72 has not been called number of calls 77 

25 times, flow returns to step S7 05. Once calibrate- 

position function 72 has been called number of 
calls 77 times, flow returns to Figure 7A. 

In Figure 7A, flow proceeds to step S709, 
where the sensor (s) are calibrated. Figure 7C is a 

3 0 flowchart for explaining sensor calibration 

according to the invention. 

In step S710 of Figure 7C, color 
calibration program 48 calls calibrate-sensor 
function 72. This function sends device driver 

35 calls 62 to measuring device driver 41, which in 

turn sends device commands 66 to measuring device 10 
so as to calibrate the sensor (s) . 
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In step S711, color calibration program 48 
determines if calibrate-sensor function 73 provided 
display values 82. If calibrate-sensor function 73 
did provide display values 82, color calibration 
5 program 4 8 displays the display values to the user 

in step S712. 

In step S713, color calibration program 48 
determines if calibrate-sensor function 73 has been 
called the number of time indicated by number of 
10 calls 78. If calibrate-sensor function 73 has not 

been called nun±>er of calls 78 times, flow returns 
to step S710. Once calibrate-sensor function 73 has 
been called number of calls 78 times, flow returns 
to Figure 7A. 

15 Returning to Figure 7A, flow proceeds to 

step S714, where move-to-patch function 74 is 
called. Color calibration program 4 8 provides raove- 
to-patch function 74 with color patch number 84, 
which is a logical patch number corresponding to the 

2 0 next patch that needs to be measured. Preferably, 

color patch number 84 is incremented every time a 
color patch is measured. Based on color patch 
number 84 and the type of measuring device 10, move- 
to-patch function 74 of measuring device DLL 3 8 

25 sends device driver calls 62 to device driver 41. 

Device driver 41 in turn sends device commands 66 to 
measuring device 10, which moves the sensor (s) or 
the recording medium, if appropriate, in order to 
relatively position the patch. 

30 In step S715, color calibration program 48 

determines if move-to-patch function 74 provided 
display values 85 to the program. If move-to-patch 
function 74 did provide display values 85, color 
calibration program 4 8 displays the display values 

35 to the user in step S716. 

With some color measuring devices, move-to- 
patch function 74 cannot move the sensor (s) or the 



recording medium. For example, hand-held patch 
reader 4 has no mechanism for moving its sensor (s) 
or a recording medium. Rather, the user must move 
the sensor (s) or the recording medium. In that 
5 case, display values 85 sent in step S716 instructs 

the user to perform this task, as necessary. 

In step Sill , color calibration program 48 
determines if move-to-patch function 74 has 
indicated that position of the recording medium 

10 needs to be recalibrated. If the position does need 

to be recalibrated, flow proceeds to step S718, 
where the position is recalibrated as explained 
above with reference to Figure 7B. 

Flow proceeds to step S719, where color 

15 calibration program 48 determines if move-to-patch 

function 74 needs to be called again so as to 
complete positioning of the sensor (s). Color 
calibration program 48 makes this determination by 
checking for flow control data from move-to-patch 

2 0 function 74 in the form of call -again value 86. If 

move-to-patch function 74 needs to be called again, 
flow returns to step S714. Otherwise, flow proceeds 
to step S720. 

In step S720, color calibration program 48 
25 calls make -measurement function 75. This function 

sends device driver calls 62 to measuring device 
driver 41, which in turn uses device commands 6 6 to 
instruct measuring device 10 to make a color 
measurement . Once the measuring operation is 

3 0 complete, measuring device 10 generates color 

measurement 67 based on this measuring operation and 
sends color measurement 67 to measuring device 
driver 41. Measuring device driver 41 sends this 
color measurement to make -measurement function 75 in 
3 5 measuring device DLL 3 8 in the form of color 

measurement 64, and the make -measurement function 



provides the measurement to color calibration 
program 48 as color measurement 54. 

In step S721, color calibration program 48 
determines if make -measurement function 75 provided 
5 display values 89 to the program. If make- 

measurement function 75 did provide display- 
values 89, color calibration program 48 displays the 
display values to the user in step S722 . 

In step S723, color calibration program 48 

10 determines if make -measurement function 75 has 

indicated that the sensor (s) need to be 
recalibrated. If the sensor (s) do need to be 
recalibrated, flow proceeds to step S724, where the 
sensor (s) are recalibrated as explained above with 

15 reference to Figure 7C. 

Flow proceeds to step S72 5, where color 
calibration program 48 determines if make- 
measurement function 75 needs to be called again so 
as to complete making the color measurement . Color 

20 calibration program 48 makes this determination by 

checking for flow control data from make -measurement 
function 74 in the form of call-again value 90. If 
make -measurement function 75 needs to be called 
again, flow returns to step S720. Otherwise, flow 

25 proceeds to step S726. 

In step S726, color calibration program 48 
determines if all color patches for calibrating 
color printer 1 have been measured. If more color 
patches need to be measured, flow returns to step 

30 S714. Otherwise, flow proceeds to step S727. 

In step S727, color calibration program 4 8 
generates color adjustment commands 55 based at 
least in part on color measurements 54. Color 
calibration program 4 8 sends these commands to 

3 5 printer driver 40, which in turn sends print 

commands 58 to color printer 1 so as to adjust the 
color fidelity of the printer. 
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Because each of the functions in measuring 
device DLL 3 8 accessed through measuring device 
API 12 8 makes device driver calls 62 to measuring 
device 41 for the type of color measuring device 10, 
5 color calibration program 48 is insulated from the 

differences between different types of color 
measuring devices. Furthermore, the flow control 
data for multiple calls provided to color 
calibration program 48 allows the program to call 

10 the functions the necessary number of times for each 

operation without knowing the type of the actual 
device . The display values provided to the program 
allow the program to display the display values 
appropriate for the type of measuring device 10 that 

15 is being used. Moreover, since the application 

program generates displays based on the display 
values rather than the DLL, the application program 
can package a message however it wants so as to 
permit each developer to give his application a 

2 0 unique and internally- consistent GUI. As a result, 

a block of code that accesses color measuring device 
DLL 3 8 can make color measurements with any type of 
color measuring device supported by the API, despite 
the different device driver commands needed to 

2 5 calibrate and operate the different types of 

devices . 

Included in a microfiche appendix submitted 
herewith is sample code that operates generally as 
described above. This code includes code for a 

3 0 portion of a color calibration program that makes 

color measurements using an API according to the 
invention, the API itself, and a DLL accessed 
through the API. This code is provided for 
illustrative purposes only. Other implementations 
3 5 of the color measurement code, measuring device API, 

and measuring device DLL exist that are within the 
scope and spirit of the invention. 
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Figure 8 is a block diagram for explaining 
a variation of the structure of the measuring device 
DLL according to the invention and of the API used 
to access the DLL. As shown in Figure 8, both 
5 calibrate-position function 72 and calibrate-sensor 

function 73 can provide call-again values 140 
and 141, respectively, to color calibration 
program 48. These call-again values are provided by 
these functions when they need to be called more 

10 than once in order to complete their respective 

operations . 

Because the calibration functions can 
return these call-again values to facilitate 
multiple calls, there is no need for get -device - 

15 capabilities function 71 to provide number of 

calls 77 and number of calls 78 to the calibration 
functions. Of course, get-device-capabilities 
function 71 can still be included in the API, if 
desired. 

2 0 Figure 9 is a block diagram for explaining 

another variation of the structure of the measuring 
device API according to the invention. In this 
variation, each of the functions in the API provides 
flow control data in the form of a "number of calls" 

2 5 value to indicate how many times that function 

should be called in order to complete its respective 
operation. Thus, calibrate-position function 72 
provides number of calls 143, calibrate-sensor 
function 73 provides number of calls 154, move-to- 

3 0 patch function 74 provides number of calls 155, and 

make -measurement function 7 5 provides number of 
calls 156. These values can be a total number of 
calls that need to be made to each function. For 
example, if three calls need to be made to 
3 5 calibrate-position function 72, then that function 

would provide a value of "three" each time it was 
called. Alternatively, each function can maintain 
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an internal state variable and provide the 
application program with a number of remaining calls 
that must be made in order to complete an operation. 
For example, calibrate-position function 72 would 
return a value of "three" the first time it was 
called to perform a position calibration, a "two" 
the next time, and a "one" the next time. Again, 
because each function provides the number of times 
that function needs to be called, there is no need 
for get-device-capabilities function 71. 

Various combinations of the foregoing flow 
control techniques illustrated in Figure 4, 8 and 9 
can be used for facilitating multiple calls of the 
function in measuring device DLL 38. 

While the invention is described above with 
respect to what is currently considered its 
preferred embodiments, it is to be understood that 
the invention is not limited to that described 
above. To the contrary, the invention is intended 
to cover various modifications and equivalent 
arrangements included within the spirit and scope of 
the appended claims. 



WHAT IS CLAIMED IS : 



1. Computer-executable process steps to 
provide an application programming interface (API) , 

5 the application programming interface providing a 

common interface between an application program and 
plural different types of color measuring devices 
each having at least one color measuring sensor, the 
computer-executable process steps comprising plural 

10 functions for operating any of the plural different 

types of color measuring devices, wherein in order 
to complete an operation performed by at least one 
of the plural functions, the function that performs 
the operation must be called a number of times which 

15 is different for at least two different types of 

color measuring devices, and wherein for a color 
measuring device that is being operated, the API 
provides the application program with flow control 
data of the number of times that the function must 

20 be called. 

2 . Computer-executable process steps 
according to Claim 1, wherein the flow control data 
is provided by the function which must be called the 

2 5 number of times in order to complete the operation. 

3 . Computer- executable process steps 
according to Claim 2, wherein the flow control data 
is provided in the form of a call-again value. 

30 

4. Computer- executable process steps 
according to Claim 2, wherein the flow control data 
is provided in the form of a numerical value. 



35 



5. Computer- executable process steps 
according to Claim 1, wherein the flow control data 
is provided by a separate function other than the 
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function which must be called the number of times in 
order to complete the operation. 



6. Computer-executable process steps 
5 according to Claim l, wherein functions in the API 

provide the application program with display values 
which are different for at least two different types 
of color measuring devices, the display values for 
display to a user so as to instruct the user in 
10 manipulating the color measuring device that is 

being operated. 



7. Computer- executable process steps 
according to Claim 6, wherein the plural functions 

15 for operating any of the plural different types of 

color measuring devices further comprise : 

a calibrate-position function to calibrate 
a relative position of a recording medium with 
respect to any of the plural different types of 

2 0 color measuring devices; 

a calibrate-sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices, - 
a move-to-patch function to relatively 

25 position any of the color measuring sensors and a 

color patch for any of the plural different types of 
color measuring devices, the move-to-patch function 
being provided with a logical color patch number by 
the application program; and 

30 a make -measurement function to make a color 

measurement of the patch at which any of the color 
measuring sensors is relatively positioned, the 
make -measurement function providing the application 
program with a color measurement value for the color 

35 patch. 
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8. Computer- executable process steps to 
provide an application programming interface (API) , 
the API providing a common interface between an 
application program and plural different types of 
5 color measuring devices each having at least one 

color measuring sensor, the computer-executable 
process steps comprising plural functions for 
operating any of the plural different types of color 
measuring devices, the plural functions comprising: 

10 a calibrate-position function to calibrate 

a relative position of a recording medium with 
respect to any of the plural different types of 
color measuring devices; 

a calibrate-sensor function to calibrate 

15 any of the color measuring sensors of any of the 

plural different types of color measuring devices ; 

a move-to-patch function to relatively 
position any of the color measuring sensors and a 
color patch for any of the plural different types of 

20 color measuring devices, the move-to-patch function 

being provided with a logical color patch number by 
the application program; and 

a make -measurement function to make a color 
measurement of the patch at which any of the color 

25 measuring sensors is relatively positioned, the 

make -measurement function providing the application 
program with a color measurement value for the color 
patch; 

wherein in order to complete an operation 
30 performed by at least one of the plural functions, 

the function that performs the operation must be 
called a number of times which is different for at 
least two different types of color measuring 
devices, and wherein for a color measuring device 
35 that is being operated, the API provides the 

application program with flow control data of the 
number of times that the function must be called. 
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9. Computer- executable process steps 
according to Claim 8, wherein the calibrate-position 
function provides the application program with at 
least one display value that is to be displayed so 

5 as to instruct a user to position the recording 

medium or to position any of the color measuring 
sensors . 

10. Computer- executable process steps 

10 according to Claim 8, wherein the calibrate-sensor 

function provides the application program with at 
least one display value that is to be displayed so 
as to instruct the user in calibrating the sensor. 

15 11. Computer- executable process steps 

according to Claim 8, wherein the move-to-patch 
function causes the color measuring device to move 
any of the color measuring sensors so as to 
relatively position any of the color measuring 

2 0 sensors and the color patch. 

12. Computer -executable process steps 
according to Claim 8, wherein the move-to-patch 
function provides the application program with at 

25 least one display value that is to be displayed so 

as to instruct the user to manipulate any of the 
color measuring devices so as to relatively position 
any of the color measuring sensors and the color 
patch. 

30 

13 . Computer- executable process steps 
according to Claim 8, wherein the move-to-patch 
function causes the color measuring device to move 
the recording medium so as to relatively position 

3 5 any of the color measuring sensors and the color 

patch. 
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14. Computer -executable process steps 
according to Claim 8, wherein the move-to-patch 
function provides the application program with at 
least one display value that is to be displayed so 

5 as to instruct the user to move the recording medium 

so as to relatively position any of the color 
measuring sensors and the color patch. 

15. Computer-executable process steps 
10 according to Claim 8, wherein the move-to-patch 

function provides the application program with a 
recalibrate value in a case that the relative 
position of the recording medium needs to be 
recalibrated. 

15 

16. Computer-executable process steps 
according to Claim 8, wherein the make -measurement 
function provides the application program with at 
least one display value that is to be displayed so 

2 0 as to instruct the user in making the color 

measurement . 

17. Computer-executable process steps 
according to Claim 8, wherein the make -measurement 

2 5 function further provides the application program 

with a recalibrate value in a case that any of the 
color measuring sensors needs to be recalibrated. 

18 . Computer-executable process steps 

3 0 according to Claim 8, wherein the flow control data 

is provided by the function which must be called the 
number of times in order to complete the operation. 
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19. Computer-executable process steps 
according to Claim 18, wherein the flow control data 
is provided in the form of a call-again value. 



20. Computer-executable process steps 
according to Claim 18, wherein the flow control data 
is provided in the form of a numerical value . 



21. Computer-executable process steps 
according to Claim 8, wherein the plural functions 
further comprise a get -device-capabilities function 
to provide the application program with the flow 
control data. 

22 . Computer-executable process steps 
according to Claim 8, wherein the plural functions 
in the API call device driver functions for the 
plural different types of color measuring devices. 

23 . Computer-executable process steps 
according to Claim 8, wherein the computer- 
executable process steps are stored in a dynamically 
linkable library. 

24 . Computer-executable process steps 
according to Claim 8, wherein the plural different 
types of color measuring devices include XY tables 
and hand-held patch readers. 

25. Computer- executable process steps 
according to Claim 8, wherein the plural different 
types of color measuring devices include 
spectrometers and densitometers . 

26. Computer-executable process steps 
according to Claim 8, wherein the application 
program is a color calibration program. 

27. Computer- executable process steps to 
provide an application programming interface (API) , 
the API providing a common interface between an 
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application program and plural different types of 
color measuring devices each having at least one 
color measuring sensor, the computer-executable 
process steps comprising plural functions for 
5 operating any of the plural different types of color 

measuring devices, the plural functions comprising: 
a calibrate-position function to calibrate 
a relative position of a recording medium with 
respect to any of the plural different types of 

10 color measuring devices, the calibrate-position 

function providing the application program with a 
position-calibration display value that is to be 
displayed so as to instruct a user to position the 
recording medium or to position any of the color 

15 measuring sensors; 

a calibrate-sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices, 
the calibrate-sensor function providing the 

20 application program with a sensor-calibration 

display value to the application program, the 
sensor-calibration display value to be displayed so 
as to instruct the user in calibrating any of the 
color measuring sensors; 

25 a move-to-patch function to relatively 

position any of the color measuring sensors and a 
color patch for any of the plural different types of 
color measuring devices, the move-to-patch function 
being provided with a logical color patch number by 

3 0 the application program, providing the application 

program with a call -again value in a case that the 
move-to-patch function needs to be called multiple 
times to complete the relative positioning of the 
color measuring sensors and has not yet been called 

35 the multiple times, and providing the application 

program with a move-to-patch display value that is 
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to be displayed so as to instruct the user in 
positioning any of the color measuring sensors; and 

a make -measurement function to make a color 
measurement of the patch at which any of the color 
5 measuring sensors is relatively positioned^ the 

make -measurement function providing the application 
program with a color measurement value for the color 
patch, providing the application program with a 
call -again value in a case that the make -measurement 

10 function needs to be called multiple times to 

complete making the color measurement of the color 
patch and has not yet been called the multiple 
times, and providing the application program with a 
measurement display value that is to be displayed SO 

15 as to instruct the user in making the color 

measurement . 



28. Computer- executable process steps 
according to Claim 27, further comprising a get- 

2 0 device-capabilities function to provide the 

application program with a number of times that the 
calibrate-position function needs to be called so as 
to calibrate the relative position of the recording 
medium and to provide the application program with a 

25 number of times that the calibrate-sensor function 

needs to be called so as to calibrate any of the 
color measuring sensors. 



29. Computer-executable process steps 
3 0 according to Claim 27, wherein the calibrate- 

position function further provides the application 
program with a number of times that the calibrate- 
position function needs to be called so as to 
calibrate the relative position of the recording 
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30. Computer -executable process steps 
according to Claim 27, wherein the calibrate- 
position function further provides the application 
program with a call -again value in a case that the 
5 calibrate-position function needs to be called 

multiple times so as to calibrate the relative 
position of the recording medium and has not yet 
been called the multiple times. 

10 31. Computer- executable process steps 

according to Claim 27, wherein the calibrate-sensor 
function further provides the application program 
with a number of times that the calibrate-sensor 
function needs to be called so as to calibrate any 

15 of the color measuring sensors. 

32. Computer-executable process steps 
according to Claim 27, wherein the calibrate-sensor 
function further provides the application program 

2 0 with a call -again value in a case that the 

calibrate-sensor function needs to be called 
multiple times so as to calibrate any of the color 
measuring sensors and has not yet been called the 
multiple times. 

25 

33. Computer- executable process steps 
according to Claim 27, wherein the move-to-patch 
function causes the color measuring device to move 
the sensor so as to relatively position any of the 

3 0 color measuring sensors and the color patch. 

34. Computer-executable process steps 
according to Claim 27, wherein the move-to-patch 
display value instructs the user to manipulate any 

35 of the color measuring devices so as to relatively 

position any of the color measuring sensors and the 
color patch. 
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35. Computer -executable process steps 
according to Claim 27, wherein the move-to-patch 
function causes any of the color measuring devices 
to manipulate any of the color measuring devices so 
5 as to relatively position any of the color measuring 

sensors and the color patch. 



36. Computer-executable process steps 
according to Claim 27, wherein the move-to-patch 
10 display value instructs the user to manipulate any 

of the color measuring devices so as to relatively 
position any of the color measuring sensors and the 
color patch. 



37. Computer-executable process steps 
according to Claim 27, wherein the move-to-patch 
function further provides the application program 
with a recalibrate value in a case that the relative 
position of the recording medium needs to be 
recalibrated. 



38. Computer-executable process steps 
according to Claim 27, wherein the make -measurement 
function further provides the application program 
25 with a recalibrate value in a case that any of the 

color measuring sensors needs to be recalibrated. 



39. Computer-executable process steps 
according to Claim 27, wherein functions in the API 
30 call device driver function for the different types 

of color measuring devices . 



40. Computer-executable process steps 
according to Claim 27, wherein the computer- 
3 5 executable process steps are stored in a dynamically 

linkable library. 
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41. Computer -executable process steps 
according to Claim 27, wherein the plural different 
types of color measuring devices include XY tables 
and hand-held patch readers. 

5 

42. Computer- executable process steps 
according to Claim 27, wherein the plural different 
types of color measuring devices include 
spectrometers and densitometers. 

10 

43 . Computer- executable process steps 
according to Claim 27, wherein the application 
program is a color calibration program. 

15 44 . A dynamically linkable library (DLL) 

for making color measurements with any of plural 
different types of color measuring devices each 
having at least one color measuring sensor, the DLL 
comprising plural functions each of which is for 

2 0 operating any of the plural different types of color 

measuring devices, the plural functions comprising: 
a calibrate-position function to calibrate 
a relative position of a recording medium with 
respect to any of the plural different types of 

2 5 color measuring devices; 

a calibrate-sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices ; 

a move-to-patch function to relatively 

3 0 position any of the color measuring sensors and a 

color patch for any of the plural different types of 
color measuring devices, the move-to-patch function 
being provided with a logical color patch number; 
and 

3 5 a make -measurement function to make a color 

measurement of the patch at which any of the color 
measuring sensors is relatively positioned, the 
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make -measurement function providing a color 
measurement value for the color patch; 

wherein in order to complete an operation 
performed by at least one of the plural functions, 
5 the function that performs the operation must be 

called a number of times which is different for at 
least two different types of color measuring 
devices, and wherein for a color measuring device 
that is being operated, the DLL provides flow 
10 control data of the number of times that the 

function must be called. 



45. A color calibration program, the color 
calibration program comprising computer- executable 
15 process steps to calibrate color fidelity of a color 

printer based on color measurements made by a color 
measuring device of color patches printed on a 
recording medium by the color printer, the computer- 
executable process steps comprising: 

2 0 code to generate print data for the color 

patches; 

code to send the print data to the color 
printer so as to print the color patches on the 
recording medium; 
25 code to make color measurements of the 

color patches printed on the recording medium using 
any of plural different types of color measuring 
devices, the code to make color measurements calling 
functions provided by an application programming 

3 0 interface (API) that provides a common interface to 

the plural different types of color measuring 
devices, the code to make color measurements using 
the common interface; and 

code to calibrate the color fidelity of the 
3 5 color printer based on the color measurements. 
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46. A computer-readable medium which 
stores computer-executable process steps, the 
computer -executable process steps to provide an 
application programming interface (API) , the 
5 application programming interface providing a common 

interface between an application program and plural 
different types of color measuring devices each 
having at least one color measuring sensor, the 
computer-executable process steps comprising plural 

10 functions for operating any of the plural different 

types of color measuring devices, wherein in order 
to complete an operation performed by at least one 
of the plural functions, the function that performs 
the operation must be called a number of times which 

15 is different for at least two different types of 

color measuring devices, and wherein for a color 
measuring device that is being operated, the API 
provides the application program with flow control 
data of the number of times that the function must 



47 . A computer -readable medium according 
to Claim 46, wherein the flow control data is 
provided by the function which must be called the 
number of times in order to complete the operation. 

48. A computer- readable medium according 
to Claim 47, wherein the flow control data is 
provided in the form of a call-again value. 

49. A computer- readable medium according 
to Claim 47, wherein the flow control data is 
provided in the form of a numerical value . 



50. A computer-readable medium according 
to Claim 46, wherein the flow control data is 
provided by a separate function other than the 
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function which must be called the number of times in 
order to complete the operation. 

51. A computer-readable medium according 
to Claim 46, wherein functions in the API provide 
the application program with display values which 
are different for at least two different types of 
color measuring devices, the display values for 
display to a user so as to instruct the user in 
manipulating the color measuring device that is 
being operated. 

52 . A computer readable medium according 
to Claim 51, wherein the plural functions for 
operating any of the plural different types of color 
measuring devices further comprise: 

a calibrate-position function to calibrate 
a relative position of a recording medium with 
respect to any of the plural different types of 
color measuring devices; 

a calibrate-sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices; 

a move-to-patch function to relatively 
position any of the color measuring sensors and a 
color patch fOij: any of the plural different types of 
color measuring devices, the move-to-patch function 
being provided with a logical color patch number by 
the application program; and 

a make -measurement function to make a color 
measurement of the patch at which any of the color 
measuring sensors is relatively positioned, the 
make -measurement function providing the application 
program with a color measurement value for the color 
patch. 
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53 . A computer readable medium storing 
computer-executable process steps, the computer- 
executable process steps to provide an application 
programming interface (API) , the API providing a 
5 common interface between an application program and 

plural different types of color measuring devices 
each having at least one color measuring sensor, the 
computer-executable process steps comprising plural 
functions for operating any of the plural different 
10 types of color measuring devices, the plural 

functions comprising: 

a calibrate-position function to calibrate 
a relative position of a recording medium with 
respect to any of the plural different types of 
15 color measuring devices; 

a calibrate- sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices; 

a move-to-patch function to relatively 

2 0 position any of the color measuring sensors and a 

color patch for any of the plural different types of 
color measuring devices, the move-to-patch function 
being provided with a logical color patch number by 
the application program; and 
25 a make -measurement function to make a color 

measurement of the patch at which any of the color 
measuring sensors is relatively positioned, the 
make -measurement function providing the application 
program with a color measurement value for the color 

3 0 patch; 

wherein in order to complete an operation 
performed by at least one of the plural functions, 
the function that performs the operation must be 
called a number of times which is different for at 
35 least two different types of color measuring 

devices, and wherein for a color measuring device 
that is being operated, the API provides the 
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application program with flow control data of the 
number of times that the function must be called. 

54. A computer- readable medium according 

5 to Claim 53, wherein the calibrate-position function 

provides the application program with at least one 
display value that is to be displayed so as to 
instruct a user to position the recording medium or 
to position any of the color measuring sensors. 

10 

55. A computer -readable medium according 
to Claim 53, wherein the calibrate-sensor function 
provides the application program with at least one 
display value that is to be displayed so as to 

15 instruct the user in calibrating the sensor. 

56. A computer- readable medium according 
to Claim 53, wherein the move-to-patch function 
causes the color measuring device to move any of the 

2 0 color measuring sensors so as to relatively position 

any of the color measuring sensors and the color 
patch. 

57. A computer-readable medium according 
25 to Claim 53, wherein the move-to-patch function 

provides the application program with at least one 
display value that is to be displayed so as to 
instruct the user to manipulate any of the color 
measuring devices so as to relatively position any 

3 0 of the color measuring sensors and the color patch. 

58. A computer- readable medium according 
to Claim 53, wherein the move-to-patch function 
causes the color measuring device to move the 

3 5 recording medium so as to relatively position any of 

the color measuring sensors and the color patch. 
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59. A computer- readable medium according 
to Claim 53, wherein the move-to-patch function 
provides the application program with at least one 
display value that is to be displayed so as to 
5 instruct the user to move the recording medium so as 

to relatively position any of the color measuring 
sensors and the color patch. 



60. A computer-readable medium according 
to Claim 53, wherein the move-to-patch function 
provides the application program with a recalibrate 
value in a case that the relative position of the 
recording medium needs to be recalibrated. 

61 . A computer readable medium according 
to Claim 53, wherein the make -measurement function 
provides the application program with at least one 
display value that is to be displayed so as to 
instruct the user in making the color measurement . 

62 . A computer -readable medium according 
to Claim 53, wherein the make -measurement function 
further provides the application program with a 
recalibrate value in a case that any of the color 
measuring sensors needs to be recalibrated. 

63 . A computer readable medium according 
to Claim 53, wherein the flow control data is 
provided by the function which must be called the 
number of times in order to complete the operation. 

64 . A computer readable medium according 
to Claim 63, wherein the flow control data is 
provided in the form of a call-again value. 
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es. A computer readable medium according 
to Claim 63, wherein the flow control data is 
provided in the form of a numerical value. 

66. A computer- readable medium according 
to Claim 53, wherein the plural functions further 
comprise a get-device-capabilities function to 
provide the application program with the flow 
control data. 

67. A computer-readable medium according 
to Claim 53 , wherein the plural functions in the API 
call device driver functions for the plural 
different types of color measuring devices . 

68. A computer -readable medium according 
to Claim 53, wherein the computer-executable process 
steps are stored in a dynamically linkable library. 

69. A computer- readable medium according 
to Claim 53, wherein the plural different types of 
color measuring devices include XY tables and hand- 
held patch readers . 

70. A computer- readable medium according 
to Claim 53, wherein the plural different types of 
color measuring devices include spectrometers and 
densitometers . 

71. A computer- readable medium according 
to Claim 53, wherein the application program is a 
color calibration program. 

72. A computer- readable medium storing 
computer-executable process steps, the computer- 
executable process steps to provide an application 
programming interface (API) , the API providing a 
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common interface between an application program and 
plural different types of color measuring devices 
each having at least one color measuring sensor, the 
computer -executable process steps comprising plural 
5 functions for operating any of the plural different 

types of color measuring devices, the plural 
functions comprising: 

a calibrate-position function to calibrate 
a relative position of a recording medium with 

10 respect to any of the plural different types of 

color measuring devices, the calibrate-position 
function providing the application program with a 
position-calibration display value that is to be 
displayed so as to instruct a user to position the 

15 recording medium or to position any of the color 

measuring sensors; 

a calibrate-sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices, 

2 0 the calibrate-sensor function providing the 

application program with a sensor-calibration 
display value to the application program, the 
sensor-calibration display value to be displayed so 
as to instruct the user in calibrating any of the 

2 5 color measuring sensors; 

a move-to-patch function to relatively 
position any of the color measuring sensors and a 
color patch for any of the plural different types of 
color measuring devices, the move-to-patch function 

3 0 being provided with a logical color patch number by 

the application program, providing the application 
program with a call -again value in a case that the 
move-to-patch function needs to be called multiple 
times to complete the relative positioning of the 
3 5 color measuring sensors and has not yet been called 

the multiple times, and providing the application 
program with a move-to-patch display value that is 
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to be displayed so as to instruct the user in 
positioning any of the color measuring sensors; and 

a make -measurement function to make a color 
measurement of the patch at which any of the color 
5 measuring sensors is relatively positioned, the 

make -measurement function providing the application 
program with a color measurement value for the color 
patch, providing the application program with a 
call-again value in a case that the make -measurement 

10 function needs to be called multiple times to 

complete making the color measurement of the color 
patch and has not yet been called the multiple 
times, and providing the application program with a 
measurement display value that is to be displayed so 

15 as to instruct the user in making the color 

measurement . 



73 . A computer -readable medium according 
to Claim 72, further comprising a get-device- 

2 0 capabilities function to provide the application 

program with a number of times that the calibrate- 
position function needs to be called so as to 
calibrate the relative position of the recording 
medium and to provide the application program with a 

2 5 number of times that the calibrate- sensor function 

needs to be called so as to calibrate any of the 
color measuring sensors . 

74 . A computer -readable medium according 

3 0 to Claim 72, wherein the calibrate-position function 

further provides the application program with a 
number of times that the calibrate-position function 
needs to be called so as to calibrate the relative 
position of the recording medium. 



75. A computer-readable medium according 
to Claim 72, wherein the calibrate-position function 
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further provides the application program with a 
call -again value in a case that the calibrate- 
position function needs to be called multiple times 
so as to calibrate the relative position of the 
5 recording medium and has not yet been called the 

multiple times. 

76. A computer- readable medium according 
to Claim 72, wherein the calibrate-sensor function 
10 further provides the application program with a 

number of times that the calibrate-sensor function 
needs to be called so as to calibrate any of the 
color measuring sensors . 



77. A computer-readable medium according 
to Claim 72, wherein the calibrate-sensor function 
further provides the application program with a 
call-again value in a case that the calibrate-sensor 
function needs to be called multiple times so as to 
calibrate any of the color measuring sensors and has 
not yet been called the multiple times. 

78. A computer- readable medium according 
to Claim 72, wherein the move-to-patch function 
causes the color measuring device to move the sensor 
so as to relatively position any of the color 
measuring sensors and the color patch. 



79. A computer- readable medium according 
3 0 to Claim 72, wherein the move-to-patch display value 

instructs the user to manipulate any of the color 
measuring devices so as to relatively position any 
of the color measuring sensors and the color patch. 

35 80. A computer- readable medium according 

to Claim 72, wherein the move-to-patch function 
causes any of the color measuring devices to 
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manipulate any of the color measuring devices so as 
to relatively position any of the color measuring 
sensors and 'the color patch. 



5 81. A computer-readable medium according 

to Claim 72, wherein the move-to-patch display value 
instructs the user to manipulate any of the color 
measuring devices so as to relatively position any 
of the color measuring sensors and the color patch. 

10 

82 . A computer-readable medium according 
to Claim 72, wherein the move-to-patch function 
further provides the application program with a 
recalibrate value in a case that the relative 
15 position of the recording medium needs to be 

recalibrated . 



83 . A computer -readable medium according 
to Claim 72, wherein the make -measurement function 

2 0 further provides the application program with a 

recalibrate value in a case that any of the color 
measuring sensors needs to be recalibrated. 

84. A computer-readable medium according 
25 to Claim 72, wherein functions in the API call 

device driver function for the different types of 
color measuring devices . 



85. A computer -readable medium according 
3 0 to Claim 72, wherein the computer-executable process 

steps are stored in a dynamically linkable library. 



86. A computer-readable medium according 
to Claim 72, wherein the plural different types of 
3 5 color measuring devices include XY tables and hand- 

held patch readers. 
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87. A computer-readable medium according 
to Claim 72, wherein the plural different types of 
color measuring devices include spectrometers and 
densitometers . 

88. A computer- readable medium according 
to Claim 72, wherein the application program is a 
color calibration program. 

89. A computer- readable medium storing a 
dynamically linkable library (DLL) , the DLL for 
making color measurements with any of plural 
different types of color measuring devices each 
having at least one color measuring sensor, the DLL 
comprising plural functions each of which is for 
operating any of the plural different types of color 
measuring devices, the plural functions comprising: 

a calibrate-position function to calibrate 
a relative position of a recording medium with 
respect to any of the plural different types of 
color measuring devices; 

a calibrate-sensor function to calibrate 
any of the color measuring sensors of any of the 
plural different types of color measuring devices; 

a move-to-patch function to relatively 
position any of the color measuring sensors and a 
color patch for any of the plural different types of 
color measuring devices, the move-to-patch function 
being provided with a logical color patch number; 
and 

a make -measurement function to make a color 
measurement of the patch at which any of the color 
measuring sensors is relatively positioned, the 
make -measurement function providing a color 
measurement value for the color patch; 

wherein in order to complete an operation 
performed by at least one of the plural functions, 
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the function that performs the operation must be 
called a number of times which is different for at 
least two different types of color measuring 
devices, and wherein for a color measuring device 
5 that is being operated, the DLL provides flow 

control data of the number of times that the 
function must be called. 



90. A computer -readable medium storing a 
10 color calibration program, the color calibration 

program comprising computer-executable process steps 
to calibrate color fidelity of a color printer based 
on color measurements made by a color measuring 
device of color patches printed on a recording 
15 medium by the color printer, the computer-executable 

process steps comprising: 

code to generate print data for the color 

patches; 

code to send the print data to the color 

2 0 printer so as to print the color patches on the 

recording medium; 

code to make color measurements of the 
color patches printed on the recording medium using 
any of plural different types of color measuring 
25 devices, the code to make color measurements calling 

functions provided by an application programming 
interface (API) that provides a common interface to 
the plural different types of color measuring 
devices, the code to make color measurements using 

3 0 the common interface; and 

code to calibrate the color fidelity of the 
color printer based on the color measurements. 
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ABSTRACT OF THE DISCLOSURE 
An application programming interface (API) 
that provides a common interface between an 
application program and plural different types of 
color measuring devices each having at least one 
color measuring sensor. The API includes plural 
functions for operating any of the plural different 
types of color measuring devices. In order to 
complete an operation performed by at least one of 
the plural functions, the function that performs the 
operation must be called a number of times which is 
different for at least two different types of color 
measuring devices. For a particular color measuring 
device, the API provides the application program 
with flow control data of the number of times that 
the function must be called. This flow control data 
preferably can be provided by the function, in the 
form of a call -again value or as a numerical value, 
or by a separate function in the API such as a 
get-device-capabilities function. In some 
embodiments of the invention, a combination of these 
methods of providing the flow control data is 
utilized. Preferred functions for operating any of 
the plural different types of color measuring 
devices include a calibrate-position function, a 
calibrate-sensor function, a move-to-patch function, 
and a make -measurement function. 
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I kdcnowledgC ibe 4nty t? <ti!«:!ose Ulfomiaiioa whu^ ja mamitl to paEe&xabiiiiy as de&T^cel in 37 

CFR 11.56- 

r hertijy daim foreign prloriiy bcncfin! water 35 U.S.C. $U9(aH<0 or g363(li). of aay fotdga 
^IlC3ilcm(x} for pamn or byoixor'b c«irificate. or 5 365(3) of aay PCT istemationol ajjpHcatioa which 
designates at least ona omtntry otbcr diaii tiic Uuitol Stitss, Hated belotv aod have akn ideatiticd b^ow zay 
famsR application ft>r pauail or iavemor's oatificate. or PCT mtematiooal sppUcanoa kavlf^ a filing date 
iJCToro ihai of the i^ioiuiaa od whkli itriority Is cismei: 

(Yes/No) 

(Ximm Anpliconon No. Piled (Dav/Mo./Yt.t prioptv Oatnied| 



I hereby <4aim th« beaea wxter 35 U.S.C f 119(e) of United Stoioa pwvieidnal ^licarionCs) 
lined btlow: 

jj lpplicadoB No. 



I hereby claim &et beaefit iiwier 35 U.S.C. § 120 of my United States ^Ucation(£), or § 365(0) 
of any KTT irmiutional tpplicaiioil OesigiRUiag Oe Unitod States, listed b«l<tw and. Inso^ as l&e subject 
DiaQer eacb of tbc dums of &is opplicatioa is ttot djiulnsed in t&e prior United St^ or PCT imemadosal 
aiipUcation in ths nwamef pwovided by tlie first pfflSgrapli of 35 U.S.C. S 112, 1 adcsicwiedje die duty tfl 
disclose iBfnnmilon wincti is nauaiid u> piten«bility m dafioed in. 37 CF.R. § 1.56 wjilch becajmc availAlc 
between tbc Qibig dace of th* prior ^licarton aad tfie national or PCT iatemaiionjd filing dbtc of this 
^licction. 



Staius 

AOTl toaoaNo. Filed (DavA<o.ryr-'> f2iBni;^,lpwfli«.A6wj2222ffl 



COMKDSCP DECLARATION ANJ3 WWtX OF AtXORNEY 
FOR TAtECT AmiCATION 

1 hereby appoioi die pm&loasss assoatid vith finn and Custoiaar Number pzcmcM 
bdow lopxosccutc ibia eppticadoaaad to trsosact fill bu$inei^ in die FalOtf Sid TOdcIDaii; Omcc COHZitU^ 
th^iewitb, saA differ t^»t a]I cMxe^ndeaoe be addiesscd to tfac «(2tli<»s associated «iih diat Cuatomar 
Number: 



mZPATBiCK, CELLA,E4KFE& » SCWTO 
Customer NdibI>«r 1^14 



I h«t!^ decim fbat aU naieiooiis made licrda ^ 
stalQJKats made oa lofbrmaihiu aud bdlef aie bclicvod to ^ ma; and fivdiei dut diece ststeiTMntR were 
vwk widt the knowledge tbttt willM fiUe itatementf «iu1 rtie so niad6 are punistiable \jj tloe or 
ixtgiafoanynf. or borh. ondsr Sedkm 1001 ttf^THle ]$ of tbc Uullfid States Code aad ib&t socii WilUui falee 
StajteneiUS may {eopaidizc Oie valid^ of Htc ^^otiea or tsay paten t issa«d tbeteoa. 



91 0 yievada Av enue. San tTose. CA 05125 



Ptig QfRec Addnaa o/o Canon Ipf orfflatl QTi Svstemg. Inc^ 
ilO Irmovatzlon Drive. Irvine,- CR. ?2612 

PnW Nauie Of iiecond Joint Invaaor, If auy Todd Hewmftn 

Second In.ven»r'« rigaatiirft Job^ ^/f/NAT t^ 

Date 2/2/^ Cirtw«/Sahjeciof_iLtS^, 

Residence 75 1 Max ion Aveaue. galo Alto . CA 54:^03 



Post Office Addrea r./p _j 



oim atloii Sv;^tems. Inc- 



110 Inpovation Driva, Irving. Ca 92615 _ 



i-'ull Name of TWid Joiut luvcntor, if aay _ 
Third Invenrnr's J!ignaoir« 



Qiiza/smea of 



Post OfficR Address _ 



Foil Kams of Fourth Joint Inventor, if any 

h'CBfftb lnYcnior's signature ____________________ 

Db» , aUzcu/Subjectof. 

Residence 



Post OfBsx AcUieis 



F312VA100033!>(Riv. btmS) 



